java - 实例变量的 setter 和 getter 的 Junit 测试
全部标签 我在让这个简单的测试通过RSpec2.8时遇到了问题。我想编写一个简单的测试来检测需要参数的方法是否缺少参数(即ArgumentError:参数数量错误('x'代表'y'))。我的测试是像这样测试一个Gem模块方法:describe"#ip_lookup"doit"shouldraiseanArgumentErrorerrorifnoparameterspassed"doexpect(@geolocater.ip_lookup).toraise_error(ArgumentError)endend我的gem模块代码如下所示:moduleGeolocaterdefip_lookup(ip
例如,如果我们写classMyClassattr_accessor:somethingend但没有显式地创建带有实例变量@something的初始化方法,Ruby会自动创建吗? 最佳答案 没有。实例变量在您分配给它们之前不会被定义,并且attr_accessor不会自动这样做。尝试访问未定义的实例变量会返回nil,但未定义该变量。在您写给它们之前,它们实际上并没有被定义。attr_accessor依赖于此行为,除了定义getter/setter之外不做任何事情。您可以通过查看.instance_variables来验证这一点:cla
我想在我的开发环境中进行单元测试输出颜色。但是,我无法让它在Linux(Debian和Ubuntu)上运行。当我包含以下库时:require'minitest/autorun'require'minitest/unit'require'minitest/pride'我得到:/usr/local/rvm/gems/ruby-1.9.2-p136/gems/minitest-2.3.1/lib/minitest/pride.rb:35:in`':undefinedmethod`output'forMiniTest::Unit:Class(NoMethodError)由代码引起:MiniTe
我正在编写一个RubyGem,如果提供给其单一方法的参数无效,它可以引发ArgumentError。我如何使用RSpec为此编写测试?下面的例子展示了我想到的那种实现方式。bar方法需要一个bool参数(:baz),检查其类型以确保它实际上是一个bool值:moduleFoodefself.bar(options={})baz=options.fetch(:baz,true)validate_arguments(baz)endprivatedefself.validate_arguments(baz)raise(ArgumentError,":bazmustbeaboolean")un
我想做以下事情:我想声明一个遍历字典的类的实例变量。假设我有这个散列hash={"key1"=>"value1","key2"=>"value2","key3"=>"value3"}并且我想将每个键都作为类的实例变量。我想知道我是否可以声明迭代该散列的变量。像这样:classMyClassdefinitialize()hash={"key1"=>"value1","key2"=>"value2","key3"=>"value3"}hash.eachdo|k,v|@k=vendendend我知道这行不通!我只是放了这段代码,看看你是否能更清楚地理解我想要什么。谢谢!
以下行在ruby1.8.7中运行良好,但在1.8.6中运行不正常。我可以在1.8.6中使用什么替代方案x=[3,4,5,6,7,78,4,3,2,5,5,3]x.count(3)=>3由于在1.8.6版本中count不是Array中的方法,因此我收到此错误。这个版本有没有类似的方法? 最佳答案 x=[3,4,5,6,7,78,4,3,2,5,5,3]x.grep(3).size#=>3 关于ruby-计数Ruby1.8.6中数组中值的实例,我们在StackOverflow上找到一个类
我是Ruby的新手,我一直在尝试学习Rake、RSpec和Cucumber。我找到了一些可以帮助我测试Rake任务的代码,但我无法让它正常工作。有人告诉我:http://blog.codahale.com/2007/12/20/rake-vs-rspec-fight/放弃这个:defdescribe_rake_task(task_name,filename,&block)require"rake"describe"Raketask#{task_name}"doattr_reader:taskbefore(:all)do@rake=Rake::Application.newRake.ap
这个问题在这里已经有了答案:+=operatorappearstomodifyfrozenstring(2个答案)关闭6年前。我正在学习Ruby,我刚刚发现在使用带变量的Object#freeze方法时有一些有趣的行为。在我卡住一个变量(Fixnum或Array)之后,我仍然可以修改它!这很奇怪,因为就我而言这不应该发生并且应该引发TypeError。这是我的代码:test=666var=90#okvar+=5puts"var.frozen?#{var.frozen?}"var.freezeputs"var.frozen?#{var.frozen?}"var=testputs"var=
我有点难过。我有以下集成测试:require"spec_helper"describe"/foods",:type=>:apidoincludeRack::Test::Methodslet(:current_user){create_user!}let(:host){"http://www.example.com"}beforedologin(current_user)@food=FactoryGirl.create_list(:food,10,:user=>current_user)endcontext"viewingallfoodsownedbyuser"doit"asJSON"d
我曾经使用过Heckle,但由于ParseTree的问题,它与ruby1.9不兼容。我一直在寻找替代方案,但唯一看起来有前途的是Chaser,它没有任何明确的文档可供我使用,看看我是否可以让它与RSpec一起工作。它似乎具有Test::Unit依赖性。那么-是否有人使用任何很棒的工具来真正检查您的测试质量?或者-是否有提供比c0覆盖更好的覆盖工具?这将有助于解决同样的问题。我现在正在使用cover_me,但它是c0,就像rcov。 最佳答案 你看过Mutantgem吗??它适用于Rspec。Thereisanicetutoria